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Foreword 



rd , 



This Technical Specification (TS) has been produced by the 3 Generation Partnership Project (3GPP). 

The contents of the present document are subject to continuing work within the TSG and may change following formal 
TSG approval. Should the TSG modify the contents of the present document, it will be re-released by the TSG with an 
identifying change of release date and an increase in version number as follows: 

Version x.y.z 

where: 

X the first digit: 

1 presented to TSG for information; 

2 presented to TSG for approval; 

3 or greater indicates TSG approved document under change control. 

y the second digit is incremented for all changes of substance, i.e. technical enhancements, corrections, 
updates, etc. 

z the third digit is incremented when editorial only changes have been incorporated in the document. 
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1 Scope 

The present document provides the description of the Packet Data Convergence Protocol (PDCP). 
PDCP provides its services to the NAS at the UE or the relay at the Radio Network Controller (RNC). 
PDCP uses the services provided by the Radio Link Control (RLC) sublayer. 
The main functions of PDCP are: 

compression of redundant Network PDU control information (header compression); 

transfer of packet data protocol user data using services provided by RLC protocol. 
The following functions are not part of release 1999 but will be included in Release 2000: 

multiplexing of different RBs onto the same RLC -entity; 

transfer of states and header compression context information to target SRNC during SRNS relocation. 

2 References 

The following documents contain provisions which, through reference in this text, constitute provisions of the present 
document. 

• References are either specific (identified by date of publication, edition number, version number, etc.) or 
non-specific. 

• For a specific reference, subsequent revisions do not apply. 

• For a non-specific reference, the latest version applies. 

[1] 3G TS 25.401: "UTRAN Overall Description". 

[2] 3G TR 25.990: "Vocabulary for the UTRAN". 

[3] 3G TS 25.301: "Radio Interface Protocol Architecture". 

[4] 3G TS 25.303: "Interlayer Procedures in Connected Mode". 

[5] 3G TS 25.322: "RLC Protocol Specification". 

[6] 3G TS 25.331: "RRC Protocol Specification". 

[7] 3G TS 23. 121 : "Architectural Requirements for Release 1999". 

[8] IETF RFC 2507: "IP Header Compression". 

[9] 3G TS 23.060: "General Packet Radio Service (GPRS); Service description; Stage 2". 



Abbreviations 



For the purposes of the present document, the following abbreviations apply: 

AS Access Stratum 

C-SAP Control Service Access Point 

IETF Internet Engineering Task Force 

IP Internet Protocol 

L2 Layer 2 (data link layer) 

L3 Layer 3 (network layer) 
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NAS Non Access Stratum 

PDCP Packet Data Convergence Protocol 

PDU Protocol Data Unit 

PID Packet Identifier 

RB Radio Bearer 

RFC Request For Comments 

RLC Radio Link Control 

RRC Radio Resource Control 

RTP Real Time ProtocolSDU Service Data Unit 

TCP Transmission Control Protocol 

UDP User Datagram Protocol 

UE User Equipment 

UMTS Universal Mobile Telecommunications System 

UTRA UMTS Terrestrial Radio Access 

UTRAN UMTS Terrestrial Radio Access Network 



4 General 

4.1 Objective 

The present document describes the functionality of the UTRAN PDCP. The overall UTRAN logical architecture is 
defined in 3GPP TS 25.301 [3]. 

Network layer protocols are intended to be capable of operating over services derived from a wide variety of 
subnetworks and data links. UMTS supports several network layer protocols providing protocol transparency for the 
users of the service. At that point of view supported protocols are IPv4 and IPv6. Introduction of new network layer 
protocols to be transferred over UTRAN shall be possible without any changes to UTRAN protocols. Therefore, all 
functions related to transfer of packets from higher layers (PDCP SDUs) shall be carried out in a transparent way by the 
UTRAN network entities. This is one of the requirements for UTRAN PDCP. 

Another requirement for the PDCP is to provide functions that help to improve channel efficiency. This requirement is 
fulfilled by the possibility to implement different kinds of optimisation methods. The currently known methods are 
standardised IETF header compression algorithms. 

Multiplexing of RBs onto the same RLC entity will be included in Release 2000 but is not available in Release 1999. 
Therefore, in Release 1999 every RB, is connected to one PDCP entity and one PDCP entity is connected to one RLC 
entity. The PDCP entities are located in the PDCP sublayer. 

Every PDCP entity uses zero, one or several header compression algorithm types with certain parameters. Several 
PDCP entities may use the same algorithm type. The algorithm types and their parameters are negotiated by RRC and 
indicated to PDCP through the PDCP Control Service Access Point (PDCP-C-SAP). 

Since the adaptation of different network layer protocols to PDCP is implementation dependent, it is not defined in the 
present document. 

4.2 Overview on sublayer architecture 

Figure 1 shows the model of the PDCP within the UTRAN protocol architecture. Every PDCP-S AP uses exactly one 
PDCP entity. Each PDCP entity uses none, one or several header compression algorithm types. 
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Figure 1 : PDCP structure 

Figure 1 represents only one possible structure for PDCP and this should not restrict implementation. However, 
subclause 5.1 shall be adhered to. 



Functions 



Packet Data Convergence Protocol shall perform the following functions: 

- header compression and decompression of IP data streams (e.g., TCP/IP and RTP/UDP/IP headers)at the 
transmitting and receiving entity, respectively. The header compression method is specific to the particular 
network layer, transport layer or upper layer protocol combinations e.g. TCP/IP and RTP/UDP/IP; 

transfer of user data. Transmission of user data means that PDCP receives PDCP SDU from the NAS and 
forwards it to the RLC layer and vice versa; 

forwarding of PDCP SDUs and associated PDCP sequence numbering only when lossless SRNS relocation is to 
be supported; 

multiplexing of different RBs onto the same RLC entity. Multiplexing is not part of Release 1999 but will be 
included in Release 2000. 



5.1 Header Compression 



The header compression method is specific for each network layer protocol type. The network layer protocol type is 
indicated during PDP context activation as defined in 23.060 [9]. The header compression algorithms and their 
parameters are negotiated by RRC for each PDCP entity and indicated to PDCP through the PDCP-C-SAP. Compressor 
and decompressor initiated signalling between peer PDCP entities, during operation, is carried out in the user plane. 

The PDCP layer shall be able to support several header compression algorithms and it shall always be possible to 
extend the list of supported algorithms in the future. 
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The PDCP layer can have one or several PDCP entities. Each PDCP entity may use zero, one, or several header 
compression algorithms. It shall be possible to establish several header compression algorithms of different types 
related to one PDCP entity. Different PDCP entities may include header compression algorithms of the same type. 

Figure 1 shows an example how PDCP may be configured. 

5.1.1 Assignment of PID values 

PDCP shall be able to distinguish different types of header compression packets to handle them with a correct header 
compression algorithm and furthermore to indicate the type of the packet within a certain algorithm. This is realised by 
utilising the PID field in the PDU structure. The table is reconfigured every time the PDCP entity is reconfigured. 

The following table illustrates an example of the PID value allocation table when three arbitrary header compression 
methods (RFC 2507 [8], Methods A and B) are configured for one PDCP entity. 

Table 1 : Example of the PID value allocation table 



PID 
Value 


Optimisation method 


Packet type 





No header compression 


- 


1 


RFC2507 


Full header 


2 


RFC2507 


Compressed TCP 


3 


RFC2507 


Compressed TCP nondelta 


4 


RFC2507 


Compressed non TCP 


5 


RFC2507 


Context state 


6 


Method A 


Uncompressed TCP/IP 


7 


Method A 


Compressed TCP/IP 


8 


Method B 


Uncompressed IP/UDP/RTP 


9 


Method B 


Compressed IP/UDP/RTP 




Unassigned value 


- 



The assignment of the PID values follow the general rules listed below: 

PID value is reserved permanently for no compression; 

PID values are assigned in ascending order, starting from 1 ; 

PID values are assigned independently to each PDCP entity; 

PID values are reassigned for the PDCP entity after renegotiation of the header compression algorithms; 

the list of negotiated (or re-negotiated) header compression entities shall be examined, starting from the first one 
in the list. The number of PID values to be assigned is specified in the subclause for this algorithm; 

if there are not enough unused PID values to be assigned to a header compression algorithm, the negotiated 
header compression entities using this algorithm shall be ignored without error notification; 

PID values that are used and are not defined invalidate the PDCP PDU; 

for a certain algorithm in a PDCP entity the assignment of PID values starts from (n+1) where n is the number of 
PID values already assigned to other algorithms. The assignment is done in the order the algorithms are 
negotiated by RRC. In the example given in table 1 RFC 2507 was the first. Method A was the second and 
Method B was the third algorithm in the PDCP Info information element exchanged between peer RRC entities. 
The PID follows this order. 

The used header compression algorithm and the packet type are unambiguously known by the basis of the PID value 
and shall apply to peer PDCP entities. While transferring data, the PID values are conveyed in the field of the PDCP 
header belonging to the PDCP PDU. Any successfully negotiated algorithm may be used for header compression of a 
PDCP SDU. 
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5.1 .2 TCP/IP and UDP/IP header compression (RFC 2507) 

Detailed operation of the RFC 2507 header compression is described in clause 3 of the IETF specification 
RFC 2507 [8]. Furthermore the mechanisms related to error recovery and packet reordering are described in clauses 10 
and 11 of the RFC 2507. These mechanisms shall be included in the functionality of the header compression supported 
by PDCP. 



5.1.2.1 



Assignment of PID values for RFC2507 



The following PID values shall be assigned to the RFC 2507 header compression in the order presented in the table 
where n is the number of PID values already assigned to other algorithms. 

Table 2: PID values assigned to RFC 2507 header compression algorithm 



PID value 


Optimisation method 


Packet type 


n+1 


RFC 2507 


Full header 


n+2 


RFC 2507 


Compressed TCP 


n+3 


RFC 2507 


Compressed TCP non-delta 


n+4 


RFC 2507 


Compressed non-TCP 


n+5 


RFC 2507 


Context state 



5.2 



Multiplexing 



Multiplexing of different RBs onto the same RLC entity is not part of Release 1999 but will be included in 
Release 2000. 



5.3 



Data Transfer 



5.3.1 Data transfer over acknowledged mode RLC 

If header compression is negotiated the PDCP entity shall perform header compression upon reception of a 
PDCP-DATA.Req. The PDCP-PDU is then delivered in RLC-AM-DATA.Req to RLC. 

During operation, when the peer PDCP entity receives the PDCP-PDU in a RLC-AM-DATA.Ind primitive, the PDCP 
entity shall perform the header decompression (if negotiated) of PDCP-PDU to obtain the PDCP SDU and deliver the 
PDCP SDU to the PDCP user with the PDCP-DATA.Ind. The following figure illustrates data transfer over 
acknowledged mode RLC. 



Originator 



PDCP user 



PDCP 



PDCP-DATA.req 
► 



RLC 



RLC-AM-DATA.req 
► 



RLC-AM-DATA.cnf 
< 



Receiver 



RLC 



Acknowledgement 
•< 



PDCP 
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► 



PDCP user 



PDCP-DATA.Ind 
> 



Figure 2: PDCP data transfer over acknowledged mode RLC 
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5.3.2 Data transfer over unacknowledged and transparent mode RLC 

If header compression is negotiated the PDCP entity shall perform header compression upon reception of a 
PDCP-DATA.Req. The PDCP-PDU is then delivered in RLC-UM-DATA.Req or RLC-Tr-DATA.Req to RLC. 

When the peer PDCP entity receives the PDCP-PDU in the RLC-UM-DATA.Ind or RLC-Tr-DATA .Ind primitive, the 
PDCP entity shall perform the header decompression (if negotiated) of PDCP-PDU to obtain the PDCP SDU and 
deliver the PDCP SDU to the PDCP user with the PDCP-DATA.Ind. The following figure illustrates data transfer over 
unacknowledged and transparent mode RLC. 
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Figure 3: PDCP data transfer over unacknowledged or transparent mode RLC 



5.4 



SRNS Relocation 



Lossless SRNS relocation is only applicable when RLC is in in-sequence delivery and acknowledged mode RLC. PDCP 
will only support lossless SRNS relocation if it is 'capable' of doing so. This is indicated by RRC in the information 
element "Support for lossless SRNS relocation" in PDCP Capability and PDCP info. 

The PDCP layer shall carry out the following functions during lossless SRNS relocation: 

forwarding of PDCP SDUs and associated sequence numbering; 

transfer of the next expected PDCP SDU sequence number from UE to target SRNC and vice versa (by RRC); 
and 

- reset of PDCP entities. 

For each radio bearer, the Receive PDCP Sequence Number of the next PDCP SDU expected to be received is 
transferred from the source to target SRNC. For each radio bearer the source SRNC forwards to the target SRNC the 
downlink PDCP-SDUs. Source SRNC provides the Send PDCP SDU sequence number of the first PDCP SDU to be 
forwarded to the target SRNC. 

The target SRNC shall send to the UE the next expected UL Receive PDCP Sequence Number. The UE shall send to 
the target SRNC the DL Receive PDCP Sequence Number of the next expected PDCP SDU. The successfully 
transmitted PDCP SDUs are thus confirmed. 

The reset of all compression entities, for an RB, shall be made during SRNS relocation. Header compression is still 
possible during relocation Negotiated compression parameters remain valid during reset, but all state information is 
initialised, e.g. header compression contexts. The PDCP sequence numbers are reset to zero after relocation, if lossless 
SRNS relocation is supported. Therefore, in header compression case, the first 'compressed' packet is a full header. For 
Release 2000, it may be considered not to reset the PDCP entity, internal protocol information, i.e. states and header 
compression contexts, but to forward these from the source SRNC to target SRNC. Header compression for a PDCP 
entity can then continue from the state that it had directly before SRNS relocation. 

In the case where lossless SRNS relocation is not supported, the PDCP layer shall carry out following functions: 

- reset of PDCP entities. 
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5.4.1 PDCP Sequence Numbering 



PDCP sequence numbering is only applicable when lossless SRNS relocation is to be supported. The value of the PDCP 
sequence number ranges from to 65535. When the PDCP entity is setup for the first time for the PDCP user the PDCP 
sequence numbers are initialised to zero. 

For each radio bearer: 

an UL_Send PDCP sequence number is associated with each sent PDCP-PDU in the UE and is incremented by 
one when a PDCP PDU is delivered to RLC; 

a DL_Send PDCP sequence number is associated with each sent PDCP-PDU in the NW and is incremented by 
one when a PDCP PDU is delivered to RLC; 

an UL_Receive PDCP sequence number is associated with each received PDCP-PDU in the NW and is 
incremented by one when a PDCP PDU is received from RLC or is incremented by one for each discarded RLC 
SDU, as indicated by the RLC SDU Discard function [5]; 

a DL_Receive PDCP sequence number is associated with each received PDCP-PDU in the UE and is 
incremented by one when a PDCP PDU is received from RLC or is incremented by one for each discarded RLC 
SDU, as indicated by the RLC SDU Discard function [5]. 

PDCP sequence numbers are never decremented. 



6 Services 

6.1 Services provided to upper layers 

The following services are provided by PDCP to upper layers: 
- PDCP SDU delivery. 

6.2 Services expected from RLC layer 

For a detailed description of the following functions see [5]. 
Data transfer in acknowledged mode. 
Data transfer in unacknowledged mode. 
Data transfer in transparent mode. 
Segmentation and reassembly. 
In-Sequence delivery. 



7 Elements for layer-to-layer communication 

The interaction between the PDCP layer and other layers are described in terms of primitives where the primitives 
represent the logical exchange of information and control between the PDCP layer and other layers. The primitives shall 
not specify or constrain implementations. 

7.1 Primitives between PDCP and upper layers 

The primitives between PDCP and upper layers are shown in table 3. 



ETSI 



3G TS 25.323 version 3.1.0 Release 1999 



12 



ETSI TS 125 323 V3.1.0 (2000-03) 



Table 3: Primitives between PDCP and upper layers 



Generic Name 


Parameter 


Req. 


Ind. 


Resp. 


Conf. 


PDCP-DATA 


Data 


Data 


Not Defined 


Not Defined 


CPDCP-CONFIG 


PDCP-lnfo, RLC-SAP 


Not Defined 


Not Defined 


Not Defined 


CPDCP-RELEASE 


RLC-SAP 


Not Defined 


Not Defined 


Not Defined 












CPDCP-RELOC 


No Parameter 


Not Defined 


Not Defined 


Not Defined 



Each Primitive is defined as follows: 

a) PDCP-DATA-Req./Ind. 

PDCP-DATA-Req is used by higher user-plane protocol layers to request a transmission of higher layer 
PDU. PDCP-DATA-Ind is used to deliver PDCP SDU that has been received to upper user plane protocol 
layers. 

b) CPDCP-CONFIG-Req. 

CPDCP-CONFIG Req is used to configure and - in case of already existing PDCP entity - to reconfigure a 
PDCP entity and to assign it to the radio bearer associated with that entity. 

c) PDCP-RELEASE-Req. 

- CPDCP-RELEASE-Req is used by RRC to release a PDCP entity. 

d) CPDCP- RELOC-Req. 

- CPDCP-RELOC-Req initiates the SRNS relocation procedure in PDCP. 
The following parameters are used in the primitives: 

1) PDCP info: 

contains the parameters for each of the header compression algorithms configured to be used by one PDCP 
entity. 

2) RLC-SAP: 

- the RLC-SAP (Tr/UM/AM) used by PDCP entity when communicating with RLC sublayer. 



8 



Elements for peer-to-peer communication 



8.1 



Protocol data units 



Two different protocol data unit formats are defined in PDCP for Release 1999. This is configured for the PDCP entity 
by RRC with the information element, "PDCP PDU header" in PDCP info. 



8.2 



Formats 



A PDCP PDU is a bit string, with a length not necessarily a multiple of 8 bits. In the drawings in subclause 8.2, bit 
strings are represented by tables in which the first bit is the leftmost one on the first line of the table, the last bit is the 
rightmost on the last line of the table, and more generally the bit string is to be read from left to right and then in the 
reading order of the lines. 

SDUs are bit strings, with any nonnull length. If not compressed within PDCP an SDU is included from first bit 
onward. 



ETSI 



3G TS 25.323 version 3.1.0 Release 1999 



13 



ETSI TS 125 323 V3.1.0 (2000-03) 



8.2.1 PDCP-No-Header PDU 

The PDCP-No-Header PDU does not introduce any overhead to the PDCP SDU. The data length is not constrained to 
be an integer number of octets. 

The format of the PDCP-No-Header-PDU is shown in table 4. 

Table 4: PDCP-No-Header PDU 



Data 



8.2.2 PDCP Data PDU 

The data PDU is used to convey a payload unit containing a PDCP SDU, header compression related control signalling 
or data that has been obtained from PDCP SDU after header compression. The data length is not constrained to be an 
integer number of octets. 

The format of the PDCP-Data-PDU is shown in table 5. 

Table 5: PDCP-Data-PDU format 



PDU type 



PID 



Data 



8.3 



Parameters 



If not otherwise mentioned in the definition of each field then the bits in the parameters shall be interpreted as follows: 
the left most bit string is the first and most significant and the right most bit is the last and least significant bit. 

Unless otherwise mentioned, integers are encoded in standard binary encoding for unsigned integers. In all cases the 
bits appear ordered from MSB to LSB when read in the PDU. 



8.3.1 PDU Type 



Length: 3 bits. 

The PDU type field indicates the PDCP-data-PDU type. 



Bit 


PDU Type 


000 


PID field used for header compression information (PDCP-PDU 
format described in table 5) 


001-111 


Reserved (PDUs with this encoding are invalid for this version of the 
protocol) 



8.3.2 PID 

Length: 5 bits. 

The PID type field indicates the PDCP-data-PDU type. 



Bit 


Description 


00000 


No header compression 


00001-11111 


Dynamically negotiated header compression identifier, as described 
in subclause 5.1.1 
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PID field value defines used header compression type and packet type. One compression algorithm may reserve a 
certain amount of values irom PID field value space for different packet types. Receiving PDCP makes reverse 
operation (e.g. header decompression) according to PID field value. There is not fixed relation between PID field value 
and used optimisation / packet type, but PID field values are defined dynamically at the PDCP parameter negotiation. 

8.3.3 Data 

PDCP SDUs that have been header compressed, as described in RFC 2507 for 1999, are mapped to this field if header 
compression is negotiated. Otherwise, PDCP SDUs are mapped to this field. 



Handling of unknown, unforeseen and erroneous 
protocol data 
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